-
Notifications
You must be signed in to change notification settings - Fork 548
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
WIP: Backport 0.4.x MySQL 8 Fixes to 0.3.x #935
base: 0.3.x
Are you sure you want to change the base?
WIP: Backport 0.4.x MySQL 8 Fixes to 0.3.x #935
Conversation
@felixbuenemann are u still working on it. I will want to use MySQL 8.0 on an old ruby project. |
@imiskolee Have you tried bundling from the feature branch in my fork to see if it works? The Travis CI logs are gone, so I don't know why they failed back then. I have no recollection on which project I used it, but I'm pretty sure it worked fine. |
The behavior that used to be triggered by EXPLAIN EXTENDED has been the default for a long time and the previously deprecated EXTENDED keyword was finally removed in MySQL 8.0. To avoid breaking the spec on very old MySQL versions we just catch the SQL syntax error and retry without the EXTENDED keyword.
899e38f
to
2325197
Compare
Looks like the Travis CI setup needs some love, I'll look into it. Aside from that I fixed a missing return value for set_secure_auth on MySQL 8 due to an error in the original backport. |
The specs could fail if the /etc/mysql directory contained files that cannot be read by the user running the specs, eg. debian.cnf. Since we already specify :sslca, the :sslcapath option doesn't make any sense and can stay at the system default value.
OK, tracked down the specs errors in docker. The reason was a bad setting of This caused problems, since the specs are running asn unpriviledged user and the directory contains some files that are only accessible by root, like Since the The problem can also be reproduced with the mysql cli: su nobody -c "mysql --ssl-capath=/etc/mysql/ --ssl-mode=REQUIRED --ssl=1 --ssl-cert=/etc/mysql/client-cert.pem --ssl-key=/etc/mysql/client-key.pem --ssl-ca=/etc/mysql/ca-cert.pem --ssl-cipher=DHE-RSA-AES256-SHA"
ERROR 2026 (HY000): SSL connection error: SSL_CTX_set_default_verify_paths failed
su nobody -c "mysql --ssl-mode=REQUIRED --ssl=1 --ssl-cert=/etc/mysql/client-cert.pem --ssl-key=/etc/mysql/client-key.pem --ssl-ca=/etc/mysql/ca-cert.pem --ssl-cipher=DHE-RSA-AES256-SHA"
ERROR 1045 (28000): Access denied for user 'nobody'@'localhost' (using password: NO)
# or connects fine with --user=root |
The default dist is currently trusty, so the travis install scripts that imply the old default of precise no longer work properly. A better solution would be to update to the trusty (unsupported) or xenial (supported) environment, but this should be the most minimal change to restore the previous CI behavior.
This reverts commit d572951 because Travis CI updates rubygems with important security fixes.
which should allow to use the preinstalled 2.3.3 version.
because it can no longher be installed due to missing binaries. See: http://binaries.rubini.us/index.txt
caused by failing bundler install during rvm use. Also the 2.3 version should be preinstalled.
c612ac2
to
62c1ff9
Compare
because the specs require certs from .travis_ssl.sh installed in /etc/mysql which is inaccessible without root on macOS. A more involved fix would be to parameterize the paths in the specs and adapt the .travis_ssl.sh script to work properly on macOS.
c526dad
to
757c78f
Compare
The latest MySQL 5.7 versions ingore SSL options, if connecting over a UNIX socket and ssl-mode=REQUIRED/VERIFY_CA/VERIFY_IDENTITY is not set. Since the :ssl_mode option is not implemented in 0.3, the easierst workaround is to force connection over TCP by using the loopback IP.
It appears that none of the tested MySQL versions require this anymore.
This is required to allow password-less auth as root for the $USER.
Still working out some problems with MySQL 5.7 release versions and charset list, so added WIP marker. I also have another branch were I updated CI to Trusty, since Precise is very deprecated and being phased out on Travis CI. To reduce noise on this PR I'm doping that work on seperate branches with my own travis account. |
and fix bug, mapping them to "" instead of NULL.
* Remove hardcoded dist names from scripts, reduce dependencies * Switch from deprecated precise to trusty dist * Update SSL script to force SHA1 for MySQL 5.5 w/yaSSL on Trusty * Update MySQL install script to support MySQL 5.6 & 8.0 install * Fix MariaDB downgrade 5.6 -> 5.5 on Trusty (remove old data dir) * Update MariaDB install script to use latest MariaDB 10.x (10.3) * Add DB=mysql8 to build matrix * Add DB=mysql55 to build matrix, since MySQL 5.6 is pre-installed
and enabling fast finish, because compiling ree from source takes much longer than all other builds and errors in ree but not in 1.8.7 are highly unlikely.
OK, CI is looking good now and was upgrade to Trusty / MySQL 5.6 as default, but MySQL 8.0 uses Xenial, due to lack of packages. An additional matrix entry downgrades to MySQL 5.5 on Trusty. I've also found a bug with the encoding list, that I'll port over to master (see 091e1d5, 246013e) and added support for MariaDB 10.2 / 10.3. |
@sodabrew I think from the changes this PR is done. Please let me know, if you'd like me to split it up into multiple PRs, since it now contains fixes for CI, MariaDB 10.2/10.3 and MySQL 8.0. The CI changes also contain some fixes that are done in a similar fashion but slightly different on master… |
beacuse the PXC 8.0 is coming, I am also blocking on this feature. thanks @felixbuenemann. You're superman. |
@sodabrew Still waiting on some directions on how to proceed with this PR. |
@sodabrew Still waiting for feedback on this PR, see my comment from May 26th. |
+1 |
+1 |
This backports the MySQL 8.0 fixes from the 0.4.x series to 0.3.x.
my_bool
fix I ported the solution from Revisit PR #840 #919 instead of Usebool
instead ofmy_bool
which has been removed since MySQL 8.0.1 #840, because I think it has a lower chance of causing issues for existing users with old MySQL versions or compilers.